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О докладчике: Петр Мязин 


. Работаю в РНР-экосистеме более 10 лет 


° Веду подкаст Пятиминутка РНР 
оптирйр.ги 


. Создаю системы учёта для логистических 
компаний 


. Работаю в Групе компаний Еогмага — 
современный цифровой экспедитор о 


агоир-РЮгмага.ги 
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ЦИФРОВИЗАЦИЯ СЕРВИСОВ 
ГОВМ/ААО СВОЧУР 


п 


ЕР 


4 р. ТА ка 
1399 И Ф 5. . + 
вм т] ще 
Грузоотправитель Судоходная Ж/Д-перевозчик Автоперевозчик Клиент Морской Контролирующие 
линия терминал органы 


< 


ЕДИНЫЙ КЛИЕНТСКИЙ ПОРТАЛ ОНЛАЙН-СЕРВИСЫ 
Грузовой и финансовый Специализированные платформы для ИНТЕ ГРАЦИ Я В КОРПОРАТИВНЫЕ 
документооборот, оформление экспедиторов и грузоперевозчиков. СИСТЕМЫ 


договоров, прием обращений 
клиентов и обратная связь. 
Сервис по Т-интеграции с корпоративной ЕВР-системой и 


| 7 у юридически значимый электронный документооборот (счета- 


— - фактуры, акты) через системы СБИС и Диадок 
ЭЛЕКТРОННЫЙ ДОКУМЕНТООБОРОТ МОБИЛЬНОЕ ПРИЛОЖЕНИЕ и Передача данных в форматах ХМЕ, УЗОМ, ЕРИЕАСТ, Ехсе! и 
Погрузочные документы, инструкции по Единое информационное пространство других, через веб-сервисы (@гарпСЕ, АВЕЗТ АР!, ЗОАР), $Вр, етай 
обработке, отчеты, закрывающие документы, для клиентов, оперативная информация о в 
УПД. движении груза. и Подготовка Ехсе!-отчётов в требуемом формате с 

автоматической доставкой на почту по расписанию 


О чем доклад? 


. Об интеграции РНР-проекта с 1С 
. Делюсь личным опытом 


° Покажу интересные примеры 


. Расширение кругозора 


Объекты метаданных в 1С 


° Справочники 
Примеры: клиенты, города, список товаров или услуг 


. Документы 
Примеры: счета, акты, заказы, письма, события реального 
мира 


° Регистры 
Исторические данные (курсы валют, цены на определённую 
дату), приход/уход по складам 


® Много чего еще: бизнес-процессы, обработки, отчёты, константы, роли, 
регламентные задания... 
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оучентоовороткоРп 
$» Общие 

> № Константы 

> Ш Справочники 


Документы 
5 Нумераторы 


— 
= Посраааа 


ВходящееПисьмо 
ВходящееСообщениеСВД 
ЕжедневныйОтчет 
ИсходящееПисьмо 
ИсходящееСообщение С ВД 
ПередачаДелВАрхив 
УничтожениеДел 


На что похоже? 


* Справочники = ЕпЙу / Модели 
Примеры: клиенты, города, список товаров или услуг 


* Документы = Епу / Модели 
Примеры: счета, акты, заказы, письма, события реального 
мира 


* Регистры = История событий / Еуеп! Зоигстод / Кэш 
Исторические данные (курсы валют, цены на определённую 
дату), приход/уход по складам 


® Много чего еще: бизнес-процессы, обработки, отчёты, константы, роли, 
регламентные задания... 
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$ 
$ Общие 
> № Константы 
> Ш Справочники 
Документы 


к. Нумераторы 


— 
= Посраааа 


ВходящееПисьмо 
ВходящееСообщениеСВД 
ЕжедневныйОтчет 
ИсходящееПисьмо 
ИсходящееСообщение С ВД 
ПередачаДелВАрхив 
УничтожениеДел 


Нужно ли синхронизировать? 


. Имеем одинаковые объекты учёта в двух системах: 1С и РНР 

. Пользователи работают с веб-интерфейсом (РНР-приложением), но 
нужны данные из 1С 

* Синхронизируем только то, что реально нужно 


© 


Счета 
Акты 
Платежи 


=, РНР Низза 
2022 


Конфигурация х 


Что синхронизируем? УЕКЕЕЬ: 


? |! Номенклатура 7% 


т 


. Контрагенты (клиенты, подрядчики) 


— < Реквизиты 


<= Номенклатура 


‹ Договора с контрагентами = Хореперитиа 
. Номенклатура (товары и услуги) 


. Счета, акты, оплаты 


> [| НоменклатураПоставщиковПрисоединенные Файлы |т 


Что НЕ синхронизируем? 
. Акты сверки — этим занимается чисто бухгалтерия 
* Регламентированные отчёты (в налоговую и прочие органы) 


. Приказы о приеме на работу, переводы, увольнения (1С ЗУП) 
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1С:Шина 


Встроенный веб-кли- 
ент 


М/еБ-сервисы 


Работа с НТТР и ЕТР 


Внешнее соединение 


Текстовые документы 


Обмен данными 


НТТР-сервисы 


ХМЕ-документы 


Работа с электронной 
почтой 


Работа с файлами 


Текстовые файлы 


ВЕЗТ интерфейс 


ом 


хто 


Технология внешних 
компонентов 


НТМЕ-документы 


АикотаНоп 
СПепе/$егуег 


Способы передачи данных 
. СОМ, ООВС 


=, РНР Визза 
2022 


Кто инициатор обмена? 
Кто источник правды? 


© 


. РНР приложение 
* 1С 


° Двунаправленная синхронизация, 


используем ЦУО 


=, РНР Ризза 
2022 


® 
НТТР, ВЕФТ запрос ] (‹ й 


РНР-клиент © 1С-сервер 
КЕЗТ 
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1С ВКЕЗТ 


. 1С автоматически генерирует КЕ$ЗТ интерфейс ко 
всем прикладным данным 


. Получение списка документов, справочников, 
записей регистра 


ы Получение элемента справочника, документа 


— 
|- 
(9. 
и] 
[а м 
чеки 


* Редактирование элемента справочника, документа 


* Создание элемента справочника, документа, набора 
записей 
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Это классический КЕЗТ 


* СЕТ — получение данных 
° РОЗТ — создание объекта 
. Обновление данных: 


‹ РАТСН — указываем только те свойства, которые 
обновляем 


‹ РУТ — указываем все свойства сущности 


* ОЕЕЕТЕ — удаление объекта 


ао 


1С КЕЗТГ — выполнение команд 


* Для документа — проведение и отмена проведения 
° Для задачи — выполнение 
° Для бизнес-процесса — старт 


° Для регистра сведений — получение среза первых и среза 
последних 


* Для регистра накопления и регистра бухгалтерии — 
получение остатков, оборотов, остатков и оборотов 
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ОБака 3.0 


* П(ръ://млмм.одаа.ога 

* Ап ореп ргфосо! {ю аЙоми {Пе сгеайоп апа сопзитрйоп от 
дчегуаЫе апа ищегорегае КЕЗТТи! АР!$ та тре апа 
З4апаага мау 


* |ЗОЛЕС арргоуед, ОАЗ$|$ Запдага 


| 


ро РНР Визза 
2022 


Ореп Ваа Ргофосо! (ОБаа) 


* П(рз://еп ммкре !а.ога/мК/Ореп_Ва{а_Ргоюсо! 
. Инициатива Мсгоз$ой 2007 года 


* Открытый веб-протокол для запроса и обновления данных 
* Данные в формате ХМЁ или УЗОМ 

. Есть библиотеки на всех популярных языках 

. В том числе для РНР 

. зазу${етз/одаа-сйеперир 


. В том числе обёртки для \УИ2 и Гагауе! (не пробовал) 
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ОПа на Хабре 


. РНРи ОБа: пересаживаемся с 
велосипедов на технологию от 
М!сгоз$ой 


ЮЕръ://Пабг.сот/ги/ро$И261811/ 


. Кратко об ОШаа 
ЮЕр$://пабг.сот/ги/ро$/678614/ 
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ОБа на Хабре ОБа на РасКад!$1 


° РНР и ООа: пересаживаемся с Е ВНЕ В: 
велосипедов на технологию от 
М!сгозой 

РНР О!Ясе 365 Пьгагу. К а!о\ми/ {о реогил СВУ орегаЧоп$ арайтзЕ О!Ясе 365 гезоигсез Ма ап ЖК 292 


И6р$://пабг.сот/ги/ро$/267811/ пера а 
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РасКа2 15 15 {Не тат Сотрозег герозКогу. К арзгера{ез рис РНР расКазез пз{аНаЫе мВ Сотрозег. 


\увгет/рНр-зро РНР  @) 405 638 


зайт{5у${епп$/оЧа{а-сПепе РНР  (@) 130 631 
бант бузкетз ОГаа СИеп юг РНР Х 115 
‹ Кратко об ОВаа новь ВИ ры 
ОРАТА рготосо! сйепе адор*е4 то изе ми 1С \ 56 
и 
р5./паог.соп/ГА/ро$ паезлоЧава не блю 
ОПака \4.01 Ргодисег ог Гагаме! 42 
сиНо$Йу26/оЧакадиегу РНР  @)25771 
А ПБгагу о РНР С!аззе$ {Ба а!ом! Фог ОБата диете {о Бе еазЙу БиЙЕ апа ежепае4 ог аррепа!пв {0 а хх 17 


ВЕ Кедиез( 0 ап АР! зиррогипя ОБака $егуег-514е. 
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ОВаа — Сгарп@ОЕЁ на минималках 


. Выбор полей для чтения 


* Можно выбрать связанные/ 
вложенные объекты (№1) 

. Фильтры, отборы и условия в 
запросе 


. Сооде &: ОВаа м$ СгарпОЕ. 


—20 | 2, РНРРозза 


Примеры запросов к1С КЕЗТ 


. Выбрать товары «Молоко» с ценой менее 25 руб 


СЕТ /Сафа1о9_Товары?$Е11ег=Имя еа 'Молоко' апа Цена 1+ 2500 


ы Получить справочник контрагентов, выбрать только ключ И описание 


СЕТ /Сафа1о9_Контрагенты?$зе1есЕ=КеЕ Кеу,БезсгтретТоп 


021. =, РНР Кизза 


СЕТ /Сафа1оа Контрагенты?$зе1есЕ=ВеЕ Кеу,ПБезсг1р®1оп&Еогпа®=)зоп 


{ 
"оафа.мефааафа": "ВЕфр://192.168.20.251:8002/ЕогмагаТгапзВав /одафа/з+апаага .оЧафа/ 


$зшефадафай#Сака1оа_Контрагенты", 

"уа1ае": [{ 
"Веё Кеу": "1#598071-а56-11е5-80Ъ{#-005056а30667", 
"Резск1р+1оп": "Велоснабжение" 

},{ 
"Веё Кеу": "64#а5Е7е-{Е58Ъ-11е5-80Ъ{#-005056а30667", 
"Резскг1р+1оп": "ДЕЛФИН ДИСТРИБЬЮШЕН“" 

},{ 
"Веё Кеу": "579а1а{3-ЕЪЕЬ-11е5-80Ъ{#-005056а30667", 
"Резск1рЕ1оп": "Диамант" 

},{ 
"Веё Кеу": "с5е0с629-Есьа-11е5-80Ъ#-005056а30667", 
"Резсг1рЕ1оп": "ДС Контролз" 


},{ 
"ВеЕ_Кеу": "894494Е8-Ес9{#-11е5-80Ъ#-005056а30667", 


Ты "ИП Чевелюк Александр Васильевич" 
},{ 


Очегу-параметры запроса на чтение 


‚ $НКег — отбор при получении данных 


‚ $з@ес{ — перечисление свойств сущности, которые попадут в результат 
запроса 


. юр — ограничение количества возвращаемых записей 
‚ $$К`р — убирает из результата запроса указанное количество 
‹ $соип{ — возвращает количество записей 


‚ $тНтесоип(=аПраде(=попе) — добавляет в результат информацию о 
количестве записей 


° ФогаегБу=<Реквизит1> а$с, <Реквизит2> 4езс — сортировка 


_ 23. 
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Примеры операторов 


е Логические операции: 


`Описание Имя пир 
Раю © /Сабаюда_Города?$ЯКег=Безсирйоп ед 'Главный' 
`Неравно пе о /Сабаюа_Города?$ЯКег=Безсирйоп пе 'Пермь' 
больше или равно бе (свод Товары? 


мые К (Сие тиирынитцнно 
1Мемшвили равно 6 (Соя Товорьинитцнки 
Гомес 598 ож Товорыйетниттцена 10 о ен 100 
ы 


Примеры операторов 


® Логические операции: 


/Сабаюд_Товары?$ЯКег=Цена ада 5 9: 10 


/Сабаюд_Товары?$ЯКег=Цена $иЬ 5 91 10 
/Са{аюд_Товары?$ЯКег=Цена туч! 5 91 1000 


/Сабаюдч_Товары?$ЯКег=Цена ам 4 92 


е Группирующие операторы: 


`Описание имя пр | 
2022 


Примеры 


операторов 


е Логические операции: 


Описание 


Пример 


Возвращает {гие в том случае, если 5{г1 является подстрокой $51г2. 


/Сака!о9_Товары? 
$ЯКег=зиБтао# ("Красный Октябрь', 
Производитель) ед {гие 


$472) 


Возвращает {гие в том случае, если 51г1 заканчивается на ${г2. 


/Сака!о9_Товары? 
$ЯКег=епа$м ИВ (Производитель, 
'ООО') еда {гие 


ами ЕВ (${г1, 
$172) 


Возвращает {гие в том случае, если $51г1 начинается на $5\г2. 


/Сака!о9_Товары? 
$НКег=${аи$м/ИА (Производитель, 
'ООО') еда {гие 


зиб $ та($ г, 
Ш) 


зибз та (г, 
|| 161, 112) 


Возвращает подстроку из 511. В варианте с двумя параметрами 
возвращается строка с позиции Тп!{ и до конца строки. 


В варианте с тремя параметрами возвращается подстрока, начиная с 
позиции 1п{1 и длиной 12. 


/Сака!о9_Поставщики? 
$ИКег=зиб и та(ИНН, 1, 2) ед '77' 


сопса(${г1, 
$472) 


Возвращает строку, являющуюся результатом конкатенации ${г1 и 52. 


/Сака!о9_Поставщик? 
$ЯКег=сопса (сопса*(Город, ', '), 
Страна) ед 'Москва, Россия' 


Нке($г, 


Е АРЕЯ 7 т 


Возвращает {гие, если значение 51 удовлетворяет шаблону Тетр!а{е. 


м то а с кл ооо нны мае асы, Га а ева ‘Зал ма ааа овен ро рее ео РРИЫИ ЕР 


/Сака!о9_Товары?$ЯКег= 


Гр} Ро ВО Иа РРВИЬ 1 5’ РА | То“ 


Кизза 


Ф$ехрапа 
. Позволяет вместе с результатами основного запроса 
получать значения связанных сущностей 


. Позволит не запрашивать каждую сущность отдельно 
* Решает проблему М + 1 запроса 


СЕТ /Сафа1оа_Контрагенты? $ехрапа=ОсновнойДоговорКонтрагента 


СЕТ /Сафа1од_Контрагенты? $ехрапа=* 
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СЕТ /Сафа1оа_ Контрагенты? 
$зе1есЕ=ВеЕ Кеу,Безск1ре1оп, ОсновнойДоговорКонтрагента 
&$ехрапа=ОсновнойДоговорКонтрагента&хгогпа+=)зоп 


{ 


"оаафа.мефсаЧафа": «ВЕфрз: / /зегуег1с /ЕогмагАТгапзВиав /оЧа*а/зфапЧага .оафа/ 
зшефада+ай#Сака1оа_Контрагенты", 
"уа1ае": [ 
{ 
"ВеЕ Кеу": "9ЗеЕе5Ье-Е74е-11е5-80ЪЕ-005056а30667", 
"Резсг1ре1оп": "АВТОДОР Дата прекращения деятельности: 26.03.2020", 
"ОсновнойДоговорКонтрагента@пах1ца+1отт.11КОг1": 
"Сафа1оа_Контрагенты ( дата ' 9ЗеЕе5ъе-Е74е-11е5-805Е-005056а30667') / 
ОсновнойДоговорКонтрагента", 
иИДоговорКонтрагента": { 
"Оттег Кеу": "9ЗеебЪе-#74е-11е5-80ЪЕ-005056а30667", 
"Рагеп& Кеу": "00000000-0000-0000-0000-000000000000", 
"ВалютаВзаиморасчетов Кеу": "5асза39е-683а-11е0-8еЪ3-000##Ее417543", 


"Организация _кеу": "17Ъа2197-Ес1а-11ас-8155-001а9223ЪЕ33", 
"ТипЦен_Кеу": "00000000-0000-0000-0000-000000000009", 3 РНР Виза 
"ВидВзаиморасчетов Кеу": "00000000-0000-0000-0000-000000000000”, 


СЕТ /Сафа1оа_Контрагенты? 

$зе1ес+=ВеЕ Кеу,Безсг1ре1оп , ОсновнойДоговорКонтрагента/ 
Номер , ОсновнойДоговорКонтрагента/ СрокДействия 
&5ехрапа=ОсновнойДоговорКонтрагента&гогма+=3зоп 


{ 
"оафа.мееаЧафа": «ВБЕфрз: / /зегуег1с /ЕогмагАТгапзВиаВ /оЧа*а/ Е апЧага .оЧафа/ 
$шефадафа*Сака1о9 Контрагенты", 
"уа1ае": |[ 
{ 
"ВеЕ Кеу": "9ЗеЕе5Ье-Е74е-11е5-80ЪЕ-005056а30667", 
"Резсг1ре1оп": "АВТОДОР Дата прекращения деятельности: 26.03.2020", 
"ОсновнойДоговорКонтрагентапау1дае1отт1пКИхк1" : 
"Сафа1оа_Контрагенты ( ди1а ' 9ЭЗеЕе5ъе-#74е-11е5-805#-005056а30667') / 
ОсновнойДоговорКонтрагента", 
"ОсновнойДоговорКонтрагента": { 
"Номер": "13", 
"СрокДействия": "0001-01-01тТ00:00:00" 


/Сафа1оч_Контрагенты ( ди1а’88954406-36а1-11е9-8552-642737а{2048')? 
Еогма*=) оп 


{ 


"одафа.мефаЯафа": «ВЕфрз: / /зегуег1с/ГогиагатТгапзВиВ /одафа/ + апаагка .оЧа+а/ 
$тефада+а#Саеа1оа Контрагенты/@Е1етепе", 

"ВеЕ Кеу": "1Е598071-Еа56-11е5-80ЪЕ-005056а30667", 

"Резсг1рЕ1оп": "Велоснабжение", 

"КодПо0КПО": “"", 

"Соае": "000000642", 

"ГоловнойКонтрагент Кеу": "1#598071-Еа56-11е5-80Ъ#-005056аз30667", 

"ОсновнойДоговорКонтрагента_Кеу": "1#598072-Еа56-11е5-80Ъ5#-005056а30667", 

"Комментарии": "", 

"НаименованиеПолное": "000 \"Велоснабжение\"", 

"КПП": "502701001", 

"Рагеп& Кеу": "00000000-0000-0000-0000-000000000000", 

"РгеаеЕ1пеа": {а15$е, 

"ИНН": "5027210205", 


"рафа\ег$1оп": "ААААААВеЕКА4=", 
30 ‘тзто1ех"| Еа15е, 


РОТ /РОТ/РАТСН на запись в 1С 


РАТСН /Росимепе_ СчетНа0ОплатуПокупателю ( да1&4 ' 39 а2534-2аъе-11е9-8456-594427Е761 


‚ В теле сообщения /ЗО№-структура ' "Шапка": "Какая-то шапка“, 


* Используем ЧУ как ключ 
(УникальныйИдентификатор) 


. В документах могут быть 
табличные части — передаются 
как вложенные массивы 
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"Товары": [ 
{ 
"Ъ1пемашЬег": "1", 
"Номенклатура_кКеу": "с084547а-0са0-11ес-8аЪ9- 
"Содержание": "Вознаграждение", 
"Количество" : 2, 
"Цена": 100, 


"Сумма": 200, 
"ПроцентСкидки": 0, 
"СуммаСкидки": 0, 
"СтавкаНДС": "НДСо", 
"СумманДС" : о 


Запись: оптимистичные блокировки 


Проверка, что данные не изменились с момента 
считывания 


Заголовок тЕ-Мафсь НТТР-запроса РАТСН или РЕТЕТЕ 


В качестве значения заголовка должно выступать 
значение свойства рафа\егз1оп, Которое получено при 
предварительном чтении сущности 
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Выводы про 1С КЕЗТ и ОШба 


. Гибко 

. Удобно 

» Просто 

‹ В простейшем случае и библиотеки никакие не нужны! 


Е1]е деЕ сопеепЕ$( 'БЕ%фрз: / /зегуег1с/Са*а1оч_ Контрагенты? $ехрапа=* '); 
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< т 


Мч5ае“ 


=}> 1 


РНР-клиент © 1С-сервер 
НТТР (не РЕЗТ-) 


ао 


НТТР-сервисы в 1С 


Конфигурация х 
Действия * @Э г - 


. Это «контроллеры» на языке 1С Ь Е чаек 


р () Общие команды 
р [1] Группы команд 


. Функция на 1С получает входящий НТТР- Ь В Оба макеты 


+ № Общие картинки 


за П рос > 9 ХОТО-пакеты 


+ У \Меб-сервисы 
м НТТР-сервисы 


. Разбираем параметры и тело запроса ры 


. Выполняем какую-то полезную работу рт 
5) \/5-ссылки 


‹ Возвращаем НТТР-ответ авы 


р ® | Языки 


р М9 Константы - 


=, РНР Ризза 
2022 
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НТТР-сервисы вместо КЕЗТ (ОШа@)? 


‹ Генерация РОЕ- и Ехсе|-документов (УПД, счет-фактура) 
* Отправка документов по ЭДО 


. Запуск особых процедур, например «закрытие заказа» 
(внутри логика на 1С) 
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Роутер на 1С 


(@ НТТР-сервис Накладные _ т ее о 
(> ШаблоныивЕ | м м и 
Сены * РТ 
ны Свойства 


(СЕТ 
| СЕТ 


и: : 
Комментарий 


НТТР-метод (БЕТ 
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_ | НТТР-сервис Накладные: Модуль ими. 
// Функция возвращает данные М-ой строки расходной накладной. 
// Номер нужной накладной и номер строки содержатся в полученном НТТР запросе. 
и! 
// Параметры: 


// Запрос - НТТРСервисЗапрос 

// Возвращаемое значение: Ю р И М е р 
и! — НТТРСервисответ 

=] Функция СтрокибСЕТ (Запрос) 


ВЕН функции 


и! НТТР://сезс.зегуег.га/вз/Накладные.вз/000000012/Строки/1 


ионные . Параметры ОВ ["Номер"]; О 0 р а 0 ОТЧ И К а 


ЗапросНомерСтроки = Запрос .ПараметрыОВГ [ "НомерСтроки"]; 


НужныйДокумент = Документы. РасходТовара.НайтиПоНомеру (ЗапросНомерДокумента); ВХО ДЯ ще ГО 


// Обработка ошибочных ситуаций: документ не найден, номер не задан. 


[- Если НужныйДокумент = Неопределено ИЛИ НужныйДокумент.Пустая() Тогда 
Ответ = Новый НТТРСервисОтвет (404); = 


Возврат Ответ; 


МНЯ | запроса 


// Вернуть данные строки. 
СтрокаДокумента = НужныйДокумент.Товары [Число (ЗапросНомерСтроки) - 1]; 


// Преобразовать данные строки в ХМЬГ. 
ЗаписьХМГ = Новый ЗаписьхХМГг; 
` ьЬХМГ.УстановитьСтроку (); 
3 [о ЬХМЕ. ЗаписатьОбъявлениехмГ (); 
ЬХМГ.. ЗаписатьНачалоЭлемента ("апзыетг"); 


Если НужныйДокумент = Неопределено ИЛИ НужныйДокумент.Пустая() Тогда 
Ответ = Новый НТТРСервисОтвет (404); 


Возврат Ответ; 
КонецЕсли; 


// Вернуть данные строки. 
СтрокаДокумента = НужныйДокумент.Товары [Число (ЗапросНомерСтроки) - 1]; 


// Преобразовать данные строки в ХМГ. 

ЗаписьХМГ = Новый Записьхмг; 

ЗаписьХМГЬ.УстановитьСтроку (); 

ЗаписьХМГ. ЗаписатьОбъявлениехМТ. (); 
ЗаписьхмМГ.ЗаписатьНачалоЭлемента ("апзыег") ; 

ЗаписьХМЕ. ЗаписатьНачалоЭлемента ("СтрокаНакладной"); 

ЗаписьХМГ.. ЗаписатьАтрибут ("Товар", СтрокаДокумента.Товар.Наименование); 
ЗаписьХМГ. ЗаписатьАтрибут ("Цена", Строка (СтрокаДокумента.Цена)); 
ЗаписьхХМГ.. ЗаписатьАтрибут ("Количество", Строка (СтрокаДокумента. Количество) ); 


ЗаписьХМГ. ЗаписатьАтрибут ("Сумма", Строка (СтрокаДокумента.Сумма)); 
ЗаписьхХМмМГ. ЗаписатьКонецЭлемента(); 

ЗаписьхХМмГ. ЗаписатьКонецЭлемента(); 

ХМГСтрока = ЗаписьхМГ..Закрыть(); 


// Передать строку в НТТР ответ. 
Ответ = Новый НТТРСервисОтвет(200); 
Ответ.УстановитьТелоИзСтроки (ХМГСтрока); 


Возврат Ответ; 


КонецФункции 


Пример 
функции 
обработчика 
входящего 
НТТР- 
запроса 


] < о ” НТТР запрос А 


1С-клиент © РНР 


НТТР 


т 


ВЛС есть НТТР-клиент! 


ЗащищенноеСоединение = Новый ЗащищенноеСоединениебрепт5 51 (Неопределено, Новый 
СертификатыУдостоверяющихЦентровОС) ; 

Соединение = Новый НТТРСоединение ("ар1.911Пиб.сот", 443,,,, 30, ЗащищенноеСоединение); 
Запрос = Новый НТТР3Запрос ("/емепт5"); 

Ответ = Соединение. Получить (Запрос); 

Поток = Ответ.ПолучитьТелоКакПоток ( }; 

Кодировка = "итТт-8"; 


Ридер = Новый Чтение3$0м; 
Ридер.ОткрытьПоток (Поток, Кодировка); 
Результат = Прочитать 50М (Ридер); 
Ридер.Закрыть(); 


мо 


Что если запрос из 1С не дошел до 
РНР-приложения? 


. 1С-Шина ПЕр5з:/уоци.бе/Е+ аи Оли$ 


. Сервисы интеграции 


. Планы обмена Прз:/уоци.бе/-НБаМЫМКМ 


Что изменилось с момента последнего чтения? 
. Поставить задачу для команды 1С-разработчиков! 


. Использовать только РУ -модель со стороны РНР 
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Идея: веб-хуки 


* При появлении события в 1С не передавать пакет всех 
данных 

. Вызывать веб-хук: ВЕ+рз : / /рьр-рко]ес*/ар1 / 
пемТпуо1сеЕгой1С?аа1а-... 

. РНР-код сходит в 1С и сам заберет всю необходимую 
информацию (РУ -модель) 


. Проще поддерживать, меньше разработки со стороны 1С- 


команды 
=, РНРВизза 
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Совет: упрощать синхронизацию! 


. Вытягивайте справочники целиком, РУ -модель из РНР 


. Не заморачивайтесь с отправкой только изменившихся 
элементов со стороны 1С (справочники) 


° Вся разработка по максимуму на одной стороне (на РНР) 


. Сокращайте взаимодействие и необходимость координации 
РНР и 1С-команд разработчиков (1С КЕЗТ в помощь) 
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Что было в докладе, я все проспал? 


. В 1С встроено КЕЗТ АР! 


. Не хватает КЕЗТ АР!? 
Легко написать собственный НТТР-контроллер на 1С 


* Используем ЦУТО для идентификаторов 


. Начинайте с максимально простых решений (а они есть!) 


Е11е деф сопЕепЕз( ' БЕфрз: / /зегуег1с /Саеа1од_ Контрагенты? $ехрапа=* '); 
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Интеграция РНР- -проекта 15 Проголосуй за доклад № _ 


Петр Мязин. № 


ИИС ИбтиарЕр: г022. рб! 


мире ИИ. те/рецтпуа2и и, 


Рир,/ РНР! Виза 
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